﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
using Suspiros_ObjetosNegocio;
using Suspiros_Persistencia;

namespace SuspirosWeb
{
    public partial class Formulario_web111 : System.Web.UI.Page
    {

        UsuarioDAO usuarios = new UsuarioDAO();
        Usuario usuario = new Usuario();

        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
                conectaControl1("id");
        }

        protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e)
        {
            GridView1.PageIndex = e.NewPageIndex;
            conectaControl1("id");
        }

        protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
        {
            GridView1.EditIndex = -1;
            conectaControl1("id");
        }

        protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e)
        {
            usuario.Id = (int)GridView1.DataKeys[e.RowIndex].Value;
            usuarios.eliminarUsuario(usuario.Id);
            //lblResultado.Text = algo;
            GridView1.EditIndex = -1;
            conectaControl1("id");
        }

        protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
        {
            GridView1.EditIndex = e.NewEditIndex;
            conectaControl1("id");
        }

        protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
        {
            //recupera renglon que haya sido modificado, y lo actualiza
            usuario.Id = (int)GridView1.DataKeys[e.RowIndex].Value;
            usuario.Nombre = ((TextBox)(GridView1.Rows[e.RowIndex].Cells[2].Controls[0])).Text;
            usuario.ApellidoP = ((TextBox)(GridView1.Rows[e.RowIndex].Cells[3].Controls[0])).Text;
            usuario.ApellidoM = ((TextBox)(GridView1.Rows[e.RowIndex].Cells[4].Controls[0])).Text;
            usuario.Email = ((TextBox)(GridView1.Rows[e.RowIndex].Cells[6].Controls[0])).Text;
            usuario.Telefono = ((TextBox)(GridView1.Rows[e.RowIndex].Cells[7].Controls[0])).Text;
            usuario.Rol = ((TextBox)(GridView1.Rows[e.RowIndex].Cells[8].Controls[0])).Text;
            usuario.Password = ((TextBox)(GridView1.Rows[e.RowIndex].Cells[10].Controls[0])).Text;

            usuarios.actualizarUsuario(usuario);
            //lblResultado.Text = algo;
            GridView1.EditIndex = -1;
            conectaControl1("id");
        }

        protected void GridView1_Sorting(object sender, GridViewSortEventArgs e)
        {
            conectaControl1(e.SortExpression.ToString());
        }

        private void conectaControl1(string campo)
        {
            GridView1.DataSource = usuarios.obtenerUsuarios(campo);
            GridView1.DataBind();
        }

        protected void btnAgregar_Click(object sender, EventArgs e)
        {
            //Llenar Datos
            usuario.Nombre = txtNombre.Text;
            usuario.ApellidoP = txtAPaterno.Text;
            usuario.ApellidoM = txtAMaterno.Text;
            usuario.FechaNac = txtFechaNac.Text;
            usuario.Email = txtEmail.Text;
            usuario.Telefono = txtTelefono.Text;
            usuario.Rol = "cliente";//Usuario por default...
            usuario.FechaReg = DateTime.Now; //Fecha actual del registro...
            usuario.Password = txtRPass.Text;
            //Guardar usuario en bd...
            int result = Convert.ToInt32(usuarios.agregaUsuario(usuario));
            conectaControl1("id");
        } 
    }
}